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[57] ABSTRACT 

A. system for producing orthogonal control signals for 
display or tool control purposes. The orthogonal con¬ 
trol signals are generated in response to received point 
and slope data for each of a plurality of curve sec¬ 
tions. The generated control signals produce curve 
strokes which are a variable geometric portion of an 
ellipse that is constrained by the received point and 
slope data. In generating the orthogonal control sig¬ 
nals a set of four parameters are generated as interme¬ 
diate controls. The four parameters are readily trans¬ 
formed to produce rotation, scaling or other opera¬ 
tions, or are economically stored in memory as part of 
an instruction set for producing general or predeter¬ 
mined characters, symbols and graphic images from 
linked curve sections. A sequence of curve sections 
may be pieced together with smooth transitions free of 
slope discontinuities. 

31 Claims, 24 Drawing Figures 
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SYSTEM FOR GENERATING ORTHOGONAL 
CONTROL SIGNALS TO PRODUCE CURVILINEAR 
MOTION 

CROSS REFERENCE TO RELATED APPLICATION 5 

This application is a continuation-in-part of our co¬ 
pending United States patent application Ser. No. 
106,108 for DISPLAY SYSTEM filed Jan. 13, 1971. 1C 

FIELD OF THE INVENTION 

This invention relates to systems for generating or¬ 
thogonally reacting control signals for application to a 
display or tool controller and in particular relates to a 15 
system for generating control signals which react to 
produce elliptical motion. 

BACKGROUND OF THE INVENTION 

As indicated in our above-referencec copending 20 
United States patent application of the electronic dis¬ 
play system providing, for example, on the surface of 
a cathode-ray-tube a controllable series of characters 
and graphical representations is an impressively useful 
tool in information processing or system design appli- 25 
cations. See, for example, United States patents of 
Bryan et al, U.S. Pat. No. 3,205,349 or Turnage et al, 
U.S. Pat. No. 3,476,974. Additionally, physical tools 
such as lasers employed in the garment industry to cut 
sections of cloth according to predetermined patterns 30 
can be programmed to respond to the control signals 
similar to those employed in display systems to control 
the motion of the laser or other physical tool involved. 

The many complex motions, point sequences or display 
strokes which are needed in these applications involve 35 
repetitive generation of a series of control signals for 
application to the ultimate display or tool controller 
and thus often result in an extremely complex and time 
consuming series of steps and calculations in the pro¬ 
cessing electronics employed for their generation. Even 40 
so, the resulting control signals often produce motions 
which do not satisfactorily approximate the desired tra¬ 
jectories. 

Moreover, if manipulations are required between re¬ 
ceipt of the specifying parameters and the final genera- 45 
tion of the orthogonal control signals, prior art systems 
have required that the transformed orthogonal control 
signals be produced by starting from the original speci¬ 
fying input data, and thus enormously complicate the 
transformation operation. Also, transformations, such 50 
as rotations, will alter the control signals in undesired 
ways. Thus general curve transformations have been 
unavialable in prior art systems. Additionally, the gen¬ 
eration of linked curve sections joined at points where 
the slopes are equal has not previously been possible. 55 
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trol or by specific hard wired implementation and in ei¬ 
ther case provide for rapid generation of the control 
signals with a minimum of generator components or 
computer time, particularly important when a plurality 
of sections must be constructed in rapid sequence. 

The generation of the control signals from the input 
point and slope specifications is accomplished in two 
steps, a first step, governed by one of several tranfor- 
mations, depending upon different ways of specifying 
i the input constraints, produces four intermediate con¬ 
trol parameters which are then applied to a function 
generator where the four parameters are employed to 
scale quadrature phased, time varying, quarter cycle, 
sinusoidal signals. The scaled signals are then com¬ 
bined in pairs to produce the orthogonal control signals 
and, additional offset and initial position signals are 
combined with the paired time varying signals to pro¬ 
vide appropriate placement of the initial point for each 
stroke of the elliptical curve sections. Where transfor¬ 
mations, such as rotations, on the ultimately produced 
strokes of elliptical curve sections are desired, these are 
easily accomplished through predetermined scaling 
operations on the four intermediate parameters with¬ 
out the requirement for recalculation from the original 
input point and slope specifications. Rotations and 
other similar transformations do not vary the curve 
shape since the parameters are not required to be recal¬ 
culated from the starting point and slope data. 

In addition to savings in computing time and display 
speed the present invention is able to produce complex 
and most commonly used shapes from a minimum of 
strokes by employing the flexibility of elliptical curve 
sections which are, in turn, each specified by four inter¬ 
mediate parameters. The intermediate parameter ap¬ 
proach permits predetermined characters, symbols and 
graphics to be stored in very small memory areas per¬ 
mitting an extremely large repertory of predetermined 
figures which may be called up for display or tool con¬ 
trol by simply specifying a memory address without the 
need for recalculation of a series of intermediate con¬ 
trol parameters for the function generator. Addition¬ 
ally, by appropriate selection of type of point and slope 
input data, linked curves can be generated with smooth 
transitions between adjacent sections. Moreover, by 
controlling the order in which input point data is speci¬ 
fied, the cruve sections are generated in either of the 
two possible directions to further increase system flexi¬ 
bility. 

BRIEF DESCRIPTION OF THE DRAWINGS 

These and other features of the invention will be 
more fully described below in a detailed description of 
the preferred embodiment presented for purposes of 
illustration, and not by way of limitation, and in the ac¬ 
companying figures of which: 


BRIEF SUMMARY OF THE INVENTION 

The design of the present invention provides for the 
generation of orthogonally reacting control signals to 
control a display or mechanical tool system in accor¬ 
dance with input curve specifications in the form of 
points or slopes. The control signals are generated as 
one or more linked elliptical curve sections constrained 
uniquely to fit the input sepcifications of points and 
slopes. The generation of control signals can be accom¬ 
plished through either stored program computer con- 


FIG. 1 is a block diagram of basic functional compo¬ 
nents employed in the invention; 

FIG. IA presents tranformations useful in correlating 
parameters of this application with our above- 
referenced patent application; 

FIG. 2 is a graph useful in describing the principles 
of the invention; 

FIGS. 3 and 5-8 illustrate circuit diagrams for differ¬ 
ent conversions available for input data as employed in 
FIG. 1; 

FIGS. 4 and 4A show circuitry for one implementa¬ 
tion of a function generator for use in FIG. 1; 
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FIGS. 9 and 10 illustrate circuitry for an alternative 
version of a function generator for use in FIG. 1; 

FIG. 11 presents a basic functional diagram of addi¬ 
tional features of the invention; 

FIGS. 12-16 illustrate circuitry to provide different 5 
transformations which may be employed in the system 
of FIG. 11; 

FIGS. 12A, 13A, 14A and 15A present algebraic 
statements of the transformation of the corresponding 
circuitry Figures; 10 

FIG. 17 illustrates a system for generating prese¬ 
lected symbols, characters and graphics from stored in¬ 
struction sets; 

FIG. 18 illustrates circuitry for operation of the in¬ 
vention in accordance with stored program computer 15 
control; 

FIG. 19 presents a flow chart describing the program¬ 
ming for use in FIG. 18 in generating linked sections; 
and 

FIG. 20 presents a three-dimensional rotation imple- 20 
mentation for the invention. 

DETAILED DESCRIPTION OF A PREFERRED 
EMBODIMENT 

Referring now to FIG. 1 the basic functional parts of 25 
the display or tool control system according to the pres¬ 
ent invention can be understood to establish perspec¬ 
tive for more detailed descriptions of the structure of 
each part. Since a part of what is described below is 
presented in our above-referenced copending United 30 
States patent application, there will be some similarities 
between this case and that presented before. There has 
been, however, during the evolution of this design a 
change of notation which is reflected in the equations 
of FIG. 1A. These provide the correspondence be- 33 
tween parameters employed in the present application 
and those of the previous case. With specific reference 
now to FIG. 1, an input source 12 such as a keyboard 
or a set of registers for point and slope data is provided 
from which one or more sets of point and slope infor- 40 
mation is provided to a data converter 14. The data 
converter 14 is programmed by hard wired intercon¬ 
nection of a plurality of digital modules as will be ex¬ 
plained below, or through software commands in a 
computer as will also be more fully described below. 45 
The converter 14 responds to the point and slope input 
information from source 12 to provide a plurality of 
output parameter signals to a function generator 16. 

The output parameters include initial points in orthog¬ 
onal X and Y coordinates (XO and YO) for each curve 50 
section to be generated as well as four additional pa¬ 
rameters labeled with the notation J, K, L and M which 
define each stroke. The function generator 16 receives 
the initial point coordinates and the four parameters (J, 

K, L and M) and employs them to scale quadrature 55 
phased sinusoidal signals according to a predetermined 
relationship. The resulting scaled signals are then 
summed in pairs with one of the parameters and with 
the initial point coordinates to produce corresponding 
orthogonally reacting, time varying control signals la¬ 
beled as X(t) and Y (t) on lines 18 and 20. The output 
control signals are applied to a display or other utiliza¬ 
tion device 22. 

The X and Y control signals from the generator 16 6J 
may be in digital or analog form and in the former will 
be converted to analog form by a digital-to-analog con¬ 
verter 24 for use by analog inputs of such display de- 
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vices as an X-Y cathode-ray-tube 26, scan converter 28 
and associated television monitor 30, direct view stor¬ 
age tube 32, or X-Y plotter 34. An enabled signal is 
provided to a blanking circuit 36 which causes marking 
by the displays only during the selected portion of a 
cycle of the quadrature phased sinusoidal signals. In 
other embodiments the X and Y control signal outputs 
of the generator 16 are in digital incremental form 
wherein each pulse output represents a predetermined 
positioning change for the display or other utilization 
device 22. The incremental pulse signals are ideally 
suited for application to an incremental digital plotter 
38 or numerically controlled tool system 40. 

A significant factor in the efficiency of the present 
system is the use of selected portion of an ellipse ap¬ 
proach. By reference now to FIG. 2 the mathematical 
transformations of the data converter 14 which create 
this efficiency can be more easily understood. In FIG. 
2 a curve section 42 is to be displayed or a tool system 
is to be governed by the motion represented by that 
curve. The curve will be specified from the input 
source 12 in the typical case by a set of points or points 
and slopes along the curve 42. For exemplary purposes 
in the present patent application five cases are pres¬ 
ented of different combinations of points and slopes in¬ 
cluding: { 1) beginning and ending points (P0 and PI) 
and the curve slopes, (SO and SI) respectively; (2) 
three points (P0, PI and P3) and the slope at the initial 
point (SO); (3) three points (P0, PI and P3) and the 
slope at the ending point (SI); (4) three points (P0, PI 
and P3) and the slope of the intermediate point (S3); 
and (5) beginning and ending points (P0 and PI) and 
the position of a point (P2) on the curve between be¬ 
ginning and ending points at a position which is the 
greatest distance from a straight line joining the begin¬ 
ning and ending points. 

The data converter 14 accepts point and slope infor¬ 
mation for any of these five cases and provides electri¬ 
cal output signals representative of the coordinates of 
the beginning point P0 (X0, Y0) and four intermediate 
parameters J, K, L and M which specify the curve on 
the basis of a quarter cycle ellipse. The mathematics 
which govern this conversion in the five cases is pres¬ 
ented below. 

CASE I 

INPUT: X0; Y0; XI; Yl; SO; SI 
LET: A=X1—X0; B=Y1-Y0 
OUTPUT: 

X0; Y0 

J=( SO A—B)/( S1—SO ) 

K=A+J 
L=S1J 
M=B+L 
CASE II 

INPUT: X0; Y0; XI; Yl; X3; Y3; SO 
LET: 

A=X1—X0; B=Y1—Y0 
C=X1—X3; D=Y1—Y3 
E=(S0C—D)/(S1A—B); F= Vl-(E) (E) 

OUTPUT: 

X0; Y0 

K=(AE-C)/(E-!-F-l) 

J=K—A 
M=S0K 
L=M—B 
CASE III 

INPUT: X0; Y0; XI; Yl; X3; Y3; SI 
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LET: 

A=X1-X0; B=Y1-Y0 
C=X3—X0; D=Y3—YO 
E=(S1C—D)/(S1A—B); F= Vt-(E) (E) 
OUTPUT: 

XO; YO 

K=[ (X3—X1 )+AF]/( E+F—1) 

J=K—A 
L=S1J 
M=L+B 
CASE IV 

INPUT: XO; YO; XI; Yl; X3; Y3; S3 
LET: 

A=X1—XO; B=Y1—YO 
C=X3—XO; D=Y3—YO 
H=X3—XI; I=Y3—Yl 
G=( S3C—D )/S3H—I); 

E=[ 1 (G( V2G-1)]/[1+(G) (G)J 
F= VI—(E) (E) 

OUTPUT: 

XO; YO 

J=( C—AF)/( E+F— 1) 

K=J+A 

L=(D-BF)/(E+F-1) 

M=L+B 
CASE V 

INPUT: XO; YO; XI; Yl; X2; Y2 
LET: 

A=X1—XO; B=Y1—YO 
C=X2—XO; D=Y2—YO 
R= 1 / VT; T=1 / V2-1 
OUTPUT: 

XO; YO; 

J=(C—AR)T 
K=J+A 
L=(D—BR)T 

M=L+B __ _.. 

Any of the above five cases governing the operation 
of the data converter 14 will produce initial point XO 
and YO output coordinates plus four J, K, L and M pa¬ 
rameters for application to the function generator 16. 
Additional mathematics governing operation of the 
function generator 16 in responding to the output sig¬ 
nals from the data converter 14 to provide time varying 
X(0 and Y(t) control signals for application to a dis¬ 
play or control system 22 is indicated below. 
X(r)=J[cos(/)—1 ] + Ksin(f) + XO 
Y(t) == L[cos(r)—1] + Msin(f) +YO 
Where generally 0 « t «£ 2-7T 
typically 0 « t n/2 

Not only has it been found that elliptical sections pro¬ 
vide excellent fit characteristics for controlling the mo¬ 
tion of displays of tool mechanisms but that the genera¬ 
tion of the orthogonal X and Y controls for each stroke 
fo the mathematics indicated above is accomplished 
more simply. Also the very low density storage of pre¬ 
determined strokes in the form of the parameter out¬ 
puts from the data converter 14 enables a great variety 
of alphanumeric and graphic information to be dis¬ 
played directly from storage. The lower quantity of 
data necessitated to accurately prescribe the curve also 
insures more efficient use of data lines such as provided 
by the telephone system. Additionally, transformations 
on the generated strokes can in most cases be easily 
performed on the intermediate parameters provided by 
the data converter 14 without the necessity for recalcu¬ 
lation from original point and slope input information 
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as is common in other systems, and without creating 
unwanted distortions in the curves. Furthermore, by 
interchanging the initial and terminal points, the curve 
can be traced in the same or opposite direction to pro- 
5 vide greater flexibility. 

Consider now in detail specific implementations for 
the data converter 14 and the function generator 16 to 
provide X and Y time varying orthogonal control sig¬ 
nals in response to point and slope input data. For this 
10 purpose reference is made to FIG. 3 which shows a de¬ 
tailed schematic diagram of a possible implementation 
for the data generator 14 in case I. The converter of 
FIG. 3 receives data input from a plurality of sources 

50, 52, 54, 56, 58 and 60 which respectively contain 
15 signal values representative of XO, YO, Yl, XI, SO and 

51. The signals from the sources 50 and 62 are directly 
fed through the system to provide respective XO and 
YO output signals and are also applied respectively to 
inverting inputs of summing networks 64 and 62. The 

20 XI and Yl signals from sources 54 and 56 are applied 
respectively to noninverting inputs of networks 64 and 
62. The output of summer 62 is applied to a multipli¬ 
cand input of a multiplier 66 which receives on its mul¬ 
tiplier input the SO signal from source 58. The product 
25 output of multiplier 56 is applied to a noninverting 
input of a summer 68 while an inverting input thereof 
receives the output of summer 64. The SO and SI sig¬ 
nals from sources 58 and 60 are applied respectively to 
inverting and noninverting inputs of a summer 70 
30 which in turn provides this output to a denominator 
input of a divider circuit 72. The numerator input of di¬ 
vider 72 is provided from the output of summer 68 and 
the quotient output of divider 72, the J output of the 
converter, is applied to a noninverting input of a sum¬ 
ming network 74 and to a multiplicand input of a multi¬ 
plier 76. The summer 74 receives on a further nonin¬ 
verting input the output of summer 64 and provides this 
output as the K signal. The multiplier 76 receives on a 
40 mu * t 'Pl' er ' n P ut the SI signal from source 60 and pro¬ 
vides a product output signal as the L signal from the 
converter and also applied that signal to a noninverting 
input of a summer 78. The summer 78 receives on a 
further noninverting input the output of summer 64 
and provides its summed output as the M signal from 
the converter. 

The inputs from sources 50-60 for the converter of 
FIGS. 3 may be in either analog or digital form. If in an¬ 
alog form the summers, multipliers and dividers of the 
50 s y stem can he any of the well known analog circuits 
which provide this function. If the input is in digital 
form the summers, multipliers and divider may be digi¬ 
tal circuits and will, in typical application, be clocked 
in sequence as they occur in FIG. 3 from left to right 
55 such that each module has available all necessary in¬ 
puts at the clocking point when it must provide the digi¬ 
tal logic function indicated. 

In FIG. 4 an exemplary function generator 16 is indi¬ 
cated in detail. The J, K, M and L outputs from the data 
60 converter 14 are applied respectively to multiplicand 
inputs of multipliers 80,82, 84 and 86. The J and L sig¬ 
nals are also applied to inverting inputs of respective 
summers 88 and 90. Multiplier inputs of multipliers 80 
and 86 are provided by a time varying cosine signal 
65 from a cosine function generator 90 while multiplier 
inputs of the multipliers 82 and 84 are provided by a 
time varying sine function signal from a sine function 
generator 92. The generators 90 and 92 are controlled 
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by a time controller 94. The time controller 94 and the 
generators 90 and 92 may be of the type indicated in 
our above-referenced copending patent application as 
the unit 34, shown in FIG. 4A, in which case the quad¬ 
rature phased time varying signals are generated from 5 
a triangle wave source composed of an integrator 91 
which integrates the positive or negative values from a 
switch 89 controlled by the integrator output to pro¬ 
vide a single polarity triangle wave which is applied 
through a diode approximator 93 to provide a full wave 10 
rectified time varying sine function and through an in¬ 
verter 95 and a diode approximator 97, to provide the 
full wave rectified time varying cosine function. To 
provide quadrature phasing, the triangle wave varies 
between zero and a predetermined upper limit and the 15 
resulting outputs of the diode approximators represent 
full wave rectifications of the sine and cosine functions. 

As indicated in our above-referenced application these 
outputs are converted to the normal sine and cosine 
function signals through gates 99 and 101 which pro- 20 
vide polarity reversal on alternate cycles; summers 103 
and 105 provide the composite signals. 

The multipliers 80 and 82 provide product outputs to 
noninverting inputs of summer 88 along with the initial 
value signal (X0) and the summed output provides the 25 
time varying X(t) signal for application to a display sys¬ 
tem 22. Similarly the multipliers 84 and 86 provide 
their product outputs to noninverting inputs of summer 
90 which also receives on a further noninverting input 
the initial value Y0 signal. The sum output of the sum- 30 
mer 90 is the time varying Y(f) signal applied to the 
display system 22. 

To cause the X and Y signals to vary for a quarter 
cycle in the typical mode of use and to cause the dis¬ 
play 22 to respond only during that quarter cycle, a 35 
phase detector 94 responds to the outputs of generators 

90 and 92 to detect each of the quarter cycles from the 
generators at t= 0, rr/2, ^r and 3ir/4. These may be ac¬ 
complished using known thresholding techniques. The 
phase detector provides four outputs, one representing 40 
eqch quarter cycle point, to a logic switch 96 which se¬ 
lects one of the four outputs for application as a reset 
input to the time controller 98. The time controller re¬ 
ceives a start signal on a set input which can be used to 
enable a gate 107 within FIG. 4A to apply the positive 
and negative representations of an input to switch 89 

to cause the generation of electrical sine and cosine 
function representations from f=0. At the quarter cycle 
point, with the appropriate selection of switch 96, the 
time controller 98 is reset with the reset signal applied 50 
to discharge the integration capacitor of the integrator 

91 causing a return to the initial time condition and to 
inhibit gate 107. The reset signal from the logic 96 and 
the start signal are also applied to a mark inhibit circuit 
100 which in turn acts as a buffer for the blanking con¬ 
trols of the display system 22. Accordingly the display 
22 will be blank until the start signal is applied to the 
controller 98 and after a reset signal is applied thereto. 

A velocity compensator 102, shown also in FIG. 4A, 60 
responds to the time varying X and Y signals applied to 
the display 22 and provides an output signal represen¬ 
tative of the deviation from a reference of the square- 
root of the sum of the squares of the time derivative of 65 
the X and Y signals or approximations thereto as indi¬ 
cated in our above-referenced copending application 
and in FIG. 4A. This signal is applied to the time con- 
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trailer 98 at gate 107 which provides equal positive and 

negative representations of the input to control the 
rate of the triangle wave signal generated therein and 
adjust the velocity of the sine and cosine function sig¬ 
nals as well as the X and Y signals. The result tends to 
regulate them to a predetermined vector velocity such 
that the display intensity 22 is maintained constant. 
More sophisticated velocity control systems for use 
with tool controllers will be indicated below with refer¬ 
ence to specific designs for that purpose. A switch 109 
alternatively is activated to connect a reference 111 to 
gate 107 for a more rapid writing rate explained below. 

It is to be understood that either analog or digital im¬ 
plementation of the circuitry of FIG. 4 may be em¬ 
ployed. If the J, K, L and M signals from the generator 
14 are in digital form the multipliers 80-86 may typi¬ 
cally be multiplying digital-to-analog converters 
wherein the analog reference input is provided from 
the generators 90 and 92. In such a case digital-to- 
analog conversion must be applied on the X0, J, L and 
Y0 signals for application to the summers 88 and 90 
which would in that case normally be an analog sum¬ 
ming network. An alternative all digital implementa¬ 
tion for the function generator of FIG. 4 will be indi¬ 
cated in greater detail below. 

Additional schematic diagrams for the implementa¬ 
tion of the data converter 14 for cases II, III, IV and V 
are indicated in FIGS. 5-8, the same conventions being 
employed there as in FIG. 3. With reference to FIG. 5, 
the J, K, M and L outputs are provided as respective 
outputs of a summer 102, divider 104, multiplier 106 
and summer 108, the X0 and Y0 signals being fed di¬ 
rectly through. The summer 102 receives on an invert¬ 
ing input the output of a summer 110 and on a nonin¬ 
verting input the output of divider 104; the multiplier 
106 receives respective multiplier and multiplicand in¬ 
puts from divider 104 and the SO signal. The divider 
104 receives a numerator input from a summer 112 and 
a denominator input from a summer 114. The summer 
114 receives on noninverting inputs the output of a 
square-root circuit 116 a minus one reference signal 
118 and the output of a divider 120. The square-root 
circuit 116 receives the output from a summer 122 
which in turn receives on respective inverting and non¬ 
inverting inputs the output of a squaring circuit 124 
and the output of a one value reference 126. The squar¬ 
ing circuit 124 receives the output of the divider 120 
as does the multiplicand input of a multiplier 128. Mul¬ 
tiplier 128 receives on its multiplier input the output of 
summer 110. Multiplier 128 provides its output to sum¬ 
mer 112 on a noninverting input while an inverting 
input of summer 112 is applied from the output of a 
summer 130. The divider 120 receives respective de¬ 
nominator and numerator inputs from summers 132 
and 134. Summer 132 receives on respective nonin¬ 
verting and inverting inputs the output of a multiplier 
136 and the output of a summer 138. The summer 134 
also receives on respective noninverting and inverting 
inputs the output of a multiplier 140 and the output of 
a summer 142. Multipliers 136 and 140 respectively 
form products of the outputs of summer 110 and sum¬ 
mer 130 with the SO signal. Summers 110,138,130 and 
142 respectively receive on inverting inputs the X0, 
Y0, X3 and Y3 signals and receive respectively on non¬ 
inverting inputs the XI, Yl, XI, and Y1, signals. As in- 
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dicated above, digital or analog implementations of 
these systems may be employed as desired. 

The circuitry of FIG. 6 is similar to that of FIG. 5 in 
many details with the following differences being 
noted. The summers 130 and 142 are replaced respec- s 
tively with summers 144 and 146 which receive on re¬ 
spective inverting inputs the X0 and Y0 signals and on 
respective noninverting inputs the X3 and Y3 signals. 
The SI signal is provided in FIG. 6 in place of the SO 
signal to multipliers 136 and 140 which are provided as 10 
before as are summers 132 and 134, divider 120, squar¬ 
ing circuit 124, summing circuit 122, square rooting 
circuit 116 and summing circuit 114 along with refer¬ 
ence circuits 118 and 126. From here the differences 
which occur are indicated. A summing circuit 148 re- 15 
ceives on a noninverting input the output of summer 
144 and on an inverting input the output of summer 
110. A multiplying circuit 150 receives on respective 
multiplier and multiplicand inputs the output of sum¬ 
mer 110 and the output of square root circuit 116. The 20 
outputs of summer 148 and multiplier 150 are provided 
to noninverting inputs of a summer 152 which in turn 
provides a sum output to a numerator input of a divider 
154. The denominator input of divider 154 is provided 
from the output of summer 114 and the divider output 25 
is provided to a noninverting input of a summer 156. 

An inverting input of summer 156 is provided from the 
output of summer 110 and the output of summer 156 
provides the J signal output for the inverter. The K. sig¬ 
nal output is provided from the divider 154. Multiplier 30 
158 receives the output of summer 156 and the SI sig¬ 
nal as inputs and provides as its product output the L 
signal which is also applied to a summer 160 along with 
the output of summer 138 to provide the M output sig¬ 
nal. 

Referring now to FIG. 7 the system operative in ac¬ 
cordance with the equations of case IV is indicated and 
comprises a set of summing amplifiers 162, 164, 166, 
168, 170 and 172 which on respective inverting inputs 
receive the X0, Y0, X0, Y0, XI, and Y1 signals and on 
noninverting inputs receive respectively the XI, Yl, 

X3, Y3, X3, and Y3 signals. The output of summer 166 
is applied to a multiplicand input of a multiplier 174 
and the output of summer 170 is applied to a multipli¬ 
cand input of a multiplier 176. Multiplier inputs of mul¬ 
tipliers 174 and 176 are provided from the S3 signal 
and their respective outputs are provided to noninvert¬ 
ing inputs of summers 178 and 180. Inverting inputs of 
the summers 178 and 180 are provided respectively 
from the outputs of summers 168 and 172. Outputs of 
summers 178 and 180 are provided respectively as nu¬ 
merator and denominator inputs of a divider 182. The 
output of divider 182 is applied to multiplicand inputs 
of multipliers 184 and 186 and to the input of a squar¬ 
ing circuit 188. Multiplier 184 receives a multiplier 
input from a two value reference 190 and provides its 
output to a square root circuit 192 which in turn pro¬ 
vides its output to a noninverting input of a summer 
194. Summer 194 has an inverting input from a one 
value reference source 196. The output of summer 194 
is applied to the multiplier input of multiplier 186 
whose product output is applied to a noninverting input 
of a summer 198 along with a one value signal from a 
reference 200. The output of the squaring circuit 188 
is applied to a summing circuit 202 along with a one 
value reference from a source 204. The output of sum¬ 
mer 202 and the output of summer 198 are applied re- 
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spectively to denominator and numerator inputs of a 
divider 206 with the output thereof applied to a squar¬ 
ing circuit 208 and a noninverting input of a summer 
210. Squaring circuit 208 provides an output to an in¬ 
verting input of a summer 212 which receives on a non¬ 
inverting input a one value reference from a source 
214. The output of summer 212 is applied to a square 
root circuit 216 whose output is applied to a noninvert¬ 
ing input of summer 210 along with a minus one refer¬ 
ence signal from a source 218. The output of square 
root circuit 216 is also applied to multiplicand input of 
multipliers 220 and 222. Multiplier inputs thereof are 
provided respectively from the output of summer 162 
and the output of summer 164. Product outputs of the 
respective multipliers are applied to inverting inputs of 
respective summers 224 and 226 with noninverting in¬ 
puts received respectively from the outputs of summers 
166 and 168. The outputs of summers 224 and 226 are 
applied to numerator and denominator inputs of re¬ 
spective dividers 228 and 230. The denominator and 
numerator inputs for the dividers 228 and 230 are pro¬ 
vided from the output of summer 210. The quotient 
output of divider 228 provides the J output signal and 
is applied to a noninverting input of a summer 232 
while the quotient output of the divider 230 provides 
the L output signal and is applied to a noninverting 
input of a summer 234. Summers 232 and 234 receive 
on further noninverting inputs the outputs respectively 
of summers 162 and 164 and in turn provide the K and 
M output signals. 

With reference now to FIG. 8, the case V implemen¬ 
tation for the data converter 14 is indicated. Summers 
236,238, 240 and 242 receive respectively on inverting 
inputs the X0, X0, Y0, YO signals and on noninverting 
inputs respectively the X2, XI, Yl and Y2 signals. The 
output of summers 238 and 240 are applied respec¬ 
tively to multiplicand inputs of multipliers 244 and 246. 
Multiplier inputs thereto are provided from a refer¬ 
ence source 248 containing the value 1/ VJ. The out¬ 
puts of multiplier 244 and 246 are applied to inverting 
inputs of respective summers 248 and 250, their re¬ 
spective noninverting inputs being supplied from the 
outputs of summers 236 and 242. The outputs of sum¬ 
mers 248 and 250 are applied to multiplicand inputs of 
multipliers 252 and 254 which have their multiplier in¬ 
puts provided from a source 256 of the value 1 /( \fl 
-1). The outputs of multipliers 252 and 254 provide re¬ 
spectively the J and L output signals and are further ap¬ 
plied to noninverting inputs of summers 258 and 260. 
Additional noninverting inputs to the summers 258 and 
260 are applied respectively from the outputs of sum¬ 
mers 238 and 240 and the outputs of these summers 
258 and 260 provide the K and M output signals. 

It is to be understood that the data converter 14 may 
contain hard or soft wired versions in analog or digital 
form for all five cases and additional cases as may be 
desired. The particular transformation employed may 
be set by operator selection of one of the five cases or 
by automatic determination of the type of data supplied 
to the converter. 

Referring now to FIG. 9, a digital implementation for 
the function generator 16 is indicated in detail. The re¬ 
spective J, K, M and L signals are provided in a digital 
form to respective binary rate multiplier circuits 262, 
264, 268, and 270. The binary rate multipliers 262 and 
270 receive digital pulses from a cosine function gener¬ 
ator 272 the output thereof being a pulse stream with 
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the pulse rate representative of the sine function. The 
binary rate multipliers 264 and 268 receive similar digi¬ 
tal representations of the sine function from a sine 
function generator 274. Clocking explained below pre¬ 
vents simultaneous pulses from both generators 272 5 
and 274. The binary rate multipliers 262-270 may be 
of any standard readily available design and operate to 
adjust the rate applied to them from the generators 272 
and 274 in accordance with the magnitudes of the J, K, 

M and L signals applied to them on further inputs. The !0 
resulting outputs from the multipliers 262-270 are 
pulse rates representative of the product of the sinusoi¬ 
dal functions and the appropriate parameter from the 
data converter 14. 

The outputs of binary rate multipliers 262 and 264 I 5 
are applied to a pulse interleaving or summing network 
290 (coincident inputs being prevented by the typical 
timing of the binary rate multipliers) and the outputs of 
multipliers 268 and 270 are applied to a similar sum¬ 
ming network 292. The respective outputs of pulse 20 
summing networks 290 and 292 are applied to respec¬ 
tive pulse switches 294 and 296. Switch control for the 
pulse switch 294 is received from a direction control 
circuit 298 which receives inputs from polarity detect¬ 
ing circuits 300 and 302 and quadrant information 2 ^ 
from the time control circuit 278. The polarity circuit 
300 responds to the J signal for pulses from generator 
272 to indicate whether it is positive or negative and 
the circuit 302 responds to the K input signal for pulses 
from generator 274 to indicate whether its polarity is 30 
positive or negative. The direction control circuit 298 
operates in accordance with the following truth table: 


COUNT UP CONTROL 35 


Ouadrant 

1 

2 

3 

4 


Sign J(L) or Sign K(M) 

~ + 

+ 

+ + 

40 


Count down control results from the opposite signs 
for J and K parameters. Only one parameter is sampled 
at a given instant since a pulse from only one or the 
other of the generators 272 and 274, not both, is possi¬ 
ble during each clock interval by coordinating separate 45 
clock signal level shifts with the output pulses of gener¬ 
ators 272 and 274. These same separate shifts also con¬ 
trol circuit 298 to test the appropriate coefficient for 
the generator activated. 

The resulting count up or count down control output 50 
of the direction control circuit 298 causes the switch 
294 to correspondingly direct the pulses from the sum¬ 
ming networks 290 to a count up output line 304 or a 
count down output line 306. 

The pulse switch 296 similarly receives pulse switch- 55 
ing control from a direction controller 308 which in 
turn, receives polarity signals from polarity detectors 
310 and 312 and quadrant information from the time 
controller 278. Circuits 310 and 312 respond respec¬ 
tively to detect the polarity of the M and L input pa- 60 
rameters for pulses from generators 274 and 272. The 
above truth table indicates the response of the direc¬ 
tion control circuit 308 for the L and M coefficients. 
The pulse switch 296 in response to the direction con- 6< . 
trol signals directs the innerleaved pulses from sum¬ 
ming circuit 292 to corresponding count up or count 
down lines 314 and 316. 
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First and second reversible counters 318 and 320 re¬ 
spond respectively to the signals on lines 304 and 306 
from circuit 294 and 314 and 316 from circuit 296. A 
preset input from the X0 and Y0 signals are applied to 
counter 318 and 320 to produce initial digital values. 
The digital contents of the counters are applied to re¬ 
spective digital-to-analog converters 322 and 324 
which in turn produce analog X(r) and Y(r) signals for 
application to a display cathode-ray-tube 326. Alterna¬ 
tively the digital contents of the counters 318 and 320 
may be applied directly to devices using digital control 
signals. 

In the case of many digitally controlled positioning 
devices, stepping motors are employed to produce the 
desired motion strokes. In that case, incremental de¬ 
vices 328 are ideally adapted to receive the signals sup¬ 
plied by the lines 304, 306, 314 and 316 to provide in¬ 
cremental control over the stepping motors or similar 
devices employed therein. 

Referring now to FIG. 10 the system is indicated for 
use with a tool controller to provide both momentum 
and velocity control adapted to prevent the physical 
tool element being controlled from departing from the 
desired strokes due to excessive acceleration from too 
high a stroke velocity. 

In FIG. 10, the details of the sine and cosine function 
generators 272 and 274 and time controller 278 as well 
as the tool motion velocity controller are indicated in 
detail. In particular, the pulse rates representative of 
sine and cosine functions are provided by respective 
binary rate multipliers 325 and 327, multiplier 327 hav¬ 
ing an output delayed 1/2 clock cycle to prevent simul¬ 
taneous output. The multipliers 325 and 327 receive a 
pulse input from a clock 329 which may be held on at 
each pulse output by a hold input. Pulse scaling signals 
are received from respective switches 330 and 331 con¬ 
trolled by a decoder 332 to connect the output of re¬ 
spective sine and cosine pulse rate tables 333 and 334 
to multipliers 325 and 327 in different combinations 
depending upon the quadrant of the generator. The ta¬ 
bles 333 and 334 are standard addressable memories 
which receive address signals from a counter 335 and 
provide respective output values which reflect the dif¬ 
ferences in the sine and cosine values for the point in 
the first quadrant represented by the address of counter 
335. To permit several clock pulses to be generated for 
each address change from counter 335 a further 
counter 336 drives counter 335 from its overflow in re¬ 
sponse to clock pulse input. The total number of pulses 
from clock 329 for each address change from counter 
335 is defined by system resolution requirements while 
the important parameter in the outputs from the multi¬ 
pliers 325 and 327 is the difference in pulses for each 
address since the sine and cosine functions will ulti¬ 
mately react through the X and Y signals indepen¬ 
dently of time. 

Tables 333 and 334 contain only quarter cycle values 
and their outputs are switched between multipliers 325 
and 327 by switches 330 and 331 each quadrant signals 
from decoder 332 which receives the quadrant state 
from a 2 bit counter 337 which, in turn, is stepped by 
the overflow output of counter 335. 

The pulse outputs of multipliers 325 and 327 are ap¬ 
plied as indicated in FIG. 9 to result in incremental 
pulse output signals on lines 304, 306,314 and 316 for 
application to incrementally controlled unit 328, for 
example to X and Y stepping motors 328a and 3286 of 
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a tool 328c. The lines 304, 306, 314 and 316 are also 
applied to a digital differential analyzer 338 of standard 
design to provide an output to a digital difference cir¬ 
cuit 339 representing vector acceleration. Circuit 339 
compares the acceleration to a reference 340 and pro¬ 
vides a difference indication to delay circuits 341 and 

342 to increase or decrease the delay if the accelera¬ 
tion is respectively above or below the reference. Delay 
circuits respond to the trailing edges of both up and 
down pulses for respective X and Y signals to initiate 
delay intervals for application to respective AND gates 

343 and 344. Gates 343 and 344 respond to X and Y 
leading edge pulses as well to provide outputs through 
OR gate 345 to hold clock 329 in a pulse on state until 
the delay interval has run between pulses from multipli¬ 
ers 325 and 329. The delays effect control of the pulse 
rates and control ultimate tool motion to prevent ex¬ 
cessive accelerations. 

Alternatively, a counter 346 advances on both up 
and down X and Y pulses to register tool trajectory po¬ 
sition and address a presettable memory 347 to read 
out a predetermined control signal for delay circuits 
341 and 342. The memory 347 may be empirically 
present during a trial run of the tool to achieve maxi¬ 
mum velocity without loss of trajectory accuracy. 

A flip-flop 348 responds to a start signal to cause 
clock 329 to provide pulses, and a switch 349 responds 
to quadrant signals from decoder 332 to reset flip-flop 
348 and stop clock 329 after one or more quarter cv- 
cles. 

Turning now to FIG. 11 a further system block dia¬ 
gram is indicated and presents additional major compo¬ 
nents to provide transformations of the four intermedi¬ 
ate parameters and further to accept coding for the dis¬ 
play of predetermined symbols and characters. Ac¬ 
cordingly data converter 350, substantially of the type 
indicated in FIG. 1, is provided to receive the five re¬ 


accessed by the codes received by the processor 400. 
The control system 406 provides additional control for 
the character generations. The processor 400 provides 
direct application of the position and stroke parameters 
5 to the transformation processor 366, and ultimately for 
application to the generator 370. The plurality of sets 
of parameters called from the instructions in memory 
provide execution by the generator of the correspond¬ 
ing character as will be more fully described below. De- 
10 tails of processor 400 are indicated below. 

Referring now to FIG. 12 a detailed schematic is indi¬ 
cated for a transformation system to provide general 
rotation of strokes by any angle through direct opera- 
] tion on the J, K, L and M parameters without recalcula¬ 
tion of data from the original input information, and 
without distortions. Angle information is entered from 
a control 410 to respective cosine and sine converters 
412 and 414 which may, for example, be either diode 
2 o a PP r oximator circuits in the case of analog inputs from 
the source 410 or a look up table system in the case of 
digital inputs. The output of the cosine converter 412 
is applied to multiplicand inputs of multipliers 416, 
418, 420 and 422 while the sine output from the con- 
2S verter 414 is applied to multiplicand inputs of multipli¬ 
ers 424, 426, 428, 430. The J input is applied to the 
other inputs of multipliers 416 and 428, the L input is 
applied to the other inputs of multipliers 424 and 420, 
the K input is applied to the other inputs of multipliers 
30 418 and 430 and the M input is applied to the other in¬ 
puts of the multipliers 426 and 422. A summer circuit 
332 receives on respective noninverting and inverting 
inputs the outputs of multipliers 416 and 424, a sum¬ 
mer 334 receives on respective noninverting and in- 
35 verting inputs the output of multipliers 418 and 426, a 
summer 336 receives on noninverting inputs the output 
of multipliers 428 and 420 and the summer 338 re¬ 


spective sets of point and slope input specifications 
which are applied to corresponding data converters 
352, 354, 356, 358 and 360 as indicated in the figures 
above. A switch 362 responds to an external control 
364 to select the appropriate conversion module and 
apply the resulting output to a transformation proces¬ 
sor. The parameters are applied through a switching 
system 368 for direct application to a function genera¬ 
tor 370 or for processing by a plurality of transforma¬ 
tion system 372, 374, 376, 378 and 380 which respec¬ 
tively provide quarter turn rotations or reflections, gen¬ 
eralized rotation, scaling, or offset. The switch system 
368 responds to an external control 382 for appropri¬ 
ate selection of the desired transformation. The result¬ 
ing transformed parameters applied to the generator 
370 may also be directed to a clipping circuit 384 or di¬ 
rectly applied to a display by a switch mechanism 386 
operating in response to a further external control 388. 
The clipping circuit 384 responds to four preset inputs 
from sources 390, 392, 394, and 396 which respec¬ 
tively represent X control signal minimum and maxi¬ 
mum values and Y control minimum and maximum val¬ 
ues. 

A character and symbol processor 400 in FIG. 11 re¬ 
ceives predetermined digital input codes representing 
characters to be displayed along with positioning com¬ 
mands for the characters. The processor 400 contains 
a random access memory 402 and a read only memory 
404 which are programmable to contain instruction 
sets for a plurality of predetermined characters that are 


ceives on noninverting inputs the outputs of multipliers 
330 and 322. The outputs of the summers 332, 334, 
40 336 and 338 provide the transformed J, K, L and M pa¬ 
rameters respectively. The operation of the circuitry of 
FIG. 12 is indicated in mathematical form by asso¬ 
ciated FIG. 12A. It can be seen there that because of 
the particular character of the parameters generated 
45 for elliptical curve sections a very few operations are 
required on these intermediate parameters to provide 
any specified angle of rotation about the initial point 
X0, Y0. For linked strokes each successive initial point 
taken from the terminal point of the preceding sec- 
0 tion. The rotation is without distortion and is thus in¬ 
variant to initial stroke position. 

Referring now to FIG. 13, predetermined quarter 
turn rotations and reflections are possible with the sim- 
55 plified system presented there. Each of the original J, 
L, K and M parameters are applied to predetermined 
switches in a switch matrix 440 and are further applied 
through logical negating circuits 442,444,446 and 448 
which provide outputs that are the mathematical nega- 
6Q tive of the input magnitude. Each of the negating cir¬ 
cuits 442-448 also provide this output to predeter¬ 
mined switches in the matrix 440 as indicated in FIG. 
13. The switches in the matrix 440 are controlled by 
eight input controllers 450, 452, 454, 456, 458, 460, 
65 462 and 464. The table of FIG. 13A indicates the vari¬ 
ous rotations and reflections upon the character P 
when each of the eight control inputs operative to pro¬ 
duce a rotation are activated to close the switches 
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which they control. The eighth control 364 provides 
direct pass-through without transformation. 

In FIG. 14 an operation for producing an increase or 
decrease in the size of the generated stroke is provided 
by a scaling transformation wherein a predetermined 
scale factor 471 is applied to inputs of multipliers 470, 
472, 474 and 476. The other inputs of these multipliers 
are supplied with the J, K, L, M intermediate parame¬ 
ters and the outputs respectively provide the trans¬ 
formed parameters. FIG. 14A represents the mathe¬ 
matical operations involved. 

Referring to FIG. 15 an offsetting transformation is 
indicated for operation on the X0 and Y0 initial point 
coordinates supplied from the data converter. The X0 
and Y0 coordinates are applied to noninverting inputs 
of respective summing circuits 480 and 486. An X off¬ 
set source 488 provides an offset signal to noninverting 
input of summing circuit 480, and a Y offset source 490 
provides a Y offset signal to noninverting inputs of 
summing circuit 486. The summing sircuits 480 and 
486 provide respectively the transformed X0 and Y0 
coordinate signals as indicated in FIG. 15 for position¬ 
ing the curve and all subsequent curves to a different 
location. 

Referring now to FIG. 16 a clipping circuit for use in 
the function generator of FIG. 11 is indicated for the 
purpose of inhibiting the generation of displays except 
between predetermined X and Y limits. The sources 
390, 392, 396, and 394 for the respective X minimum, 
X maximum, Y maximum and Y minimum signals, as 
selected by associated controls, are directed respec¬ 
tively to comparator circuits 492, 494, 496 and 498 on 
reference inputs. The X(r) control signal is applied to 
comparison inputs of the comparators 492 and 494 and 
the Y(/) control signal is applied to comparison inputs 
of the comparators 496 and 498. The comparators 
492-498 indicate when the corresponding X and Y sig¬ 
nals exceed the maximum and minimum limits and pro¬ 
duce a signal indicative of that condition. The outputs 
are combined and applied to the mark inhibit circuit 
100 to produce blanking by the display whenever the 
signal exceeds those limits. The combined comparator 
outputs are also applied to the switch 109 of the func¬ 
tion generator velocity control circuit 102 to cause full 
velocity operation of the sine and cosine function gen¬ 
erators until the X and Y signals are again within the 
preselected bounds thereby minimizing the amount of 
time employed for the generation of curves which are 
not displayed. 

Referring now to FIG. 17 the operation of the display 
system for producing displays of preselected symbols 
and characters is indicated. A digital code representa¬ 
tive of the character or symbol to be displayed is ap¬ 
plied in a memory 449 to a pointer table 500 which re¬ 
sponds to the code to call a pointer to a predetermined 
address in memory 502. The memory 502 responds to 
the pointer as an address for stored instruction sets 
which govern the strokes used to display each charac¬ 
ter. The typical instruction set indicated in memory 
502 includes a control word (C) followed by J, K, L, M 
or X and Y parameters. The control word can indicate 
a curve, a positioning move, or an exit followed respec¬ 
tively by J, K, L and M parameters, X and Y positions, 
or the end of the set. The contents of the first five in¬ 
struction words are applied in processor 503 to a multi¬ 
plexer 504 where the control word is applied to a de¬ 
coder 505 to indicate which possible motion is re- 
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quired. If a curve is to be generated the decoder signals 
a gate 506 to apply the succeeding 4 words in memory 
to J, K, L and M registers 507 for application to the 
curve generator, and advances a counter 508 five steps 
5 to cause multiplexer 504 to receive the next five in¬ 
structions. If the control is a position signal, gate 506 
directs the next two words to X0 and Y0 registers 509 
and 510 to set new initial positions. The counter 508 in 
this case is advanced only three steps. An exit control 
10 signal causes the counter 508 to be reset. Decoder 505 
also provides a start signal to the generator 512 for 
curve generation control. Standard clocking control is 
applied to processor 503 from generator 512 stop sig¬ 
nals to sequence each stroke. The J, K, L and M param- 
15 eters for the generator 506 are provided through a scal¬ 
ing circuit 514 such as that indicated in FIG. 14. A pre¬ 
determined reduction factor is provided by the scaling 
circuit 514 to cause a transformation reducing the scale 
size of the generated characters. This enables the char- 
20 acters to be generated on a greater scale for which a 
greater number of digital numbers are available for the 
J, K, L and M parameters to provide a greater flexibility 
to the strokes which can be used to compile the individ¬ 
ual characters. The X and Y parameters may also be 
25 directed through scaling circuit 514 prior to registers 
509 and 510 if they are stored in memory 502 on an ex¬ 
panded scale. Initial position X0 and Y0 signals are re¬ 
ceived by registers 509 and 510 which respond to the 
stop signal from the generator 512 to store the value of 
30 the X(/) and Y(/) signals from the function generator 
512 when curves are generated so that the end point of 
each curve becomes the initial point for the next curve. 
The decoder 505 provides an output start signal for the 
time controller of the function generator to initiate the 
35 subsequent stroke after the multiplexer 510 has been 
indexed to the next set of stored parameters and they 
have been stored in the appropriate registers. 

With the structure of FIG. 17 highly complex charac- 
ters including complex ideographs can be generated on 
the basis of stored instructions called up by simple code 
words. The power of the generator in providing charac¬ 
ters from successive strokes of elliptic sections is in¬ 
creased in flexibility by initially generating the control 
45 parameters for the characters on a scale larger than in¬ 
tended for display. This flexibility permits very subtle 
style changes as may be desired by the user. 

The above described systems for producing display 
or tool control strokes have been generally related to 
5o the use of a hard wired system of digital logic or analog 
circuits. It is of course apparent to those skilled in the 
art that the display user will want to employ stored pro¬ 
gram control over the display or tool control functions 
in order to have the greater flexibility of changing the 
55 stored instruction sets at will. Accordingly, in FIG. 18 
a block diagram of the computerized system according 
to the invention is indicated. An input keyboard 550 is 
provided which may typically be one of the commonly 
employed tele-typewriter keyboard-printer combina- 
60 tions frequently employed to provide data to a mini¬ 
computer 552. Computer 552 may typically be the 
model PDP-11 of the Digital Equipment Corporation in 
Maynard, Massachusetts. The keyboard 550 is used to 
provide the point and slope input information to the 
65 com P uter 552 which in turn provides the data conver¬ 
sion indicated for the cases I—V presented above or 
provides additional control functions as may be de¬ 
sired. The computer 552 may also incorporate the 
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mathematical equations which provide for rotation, 
scaling or offsetting as indicated for the transformation 
processor in FIG. 11. Alternatively the transformations 
may be accomplished in a processor 554 which re¬ 
ceives the J, K, L and M parameter outputs of the com¬ 
puter 552 as well as the X0 and Y0 initial points where 
appropriate. Typically, the processor 554 will have a 
plurality of registers 556, 558, 560, 562, 564 and 566 
which are loaded respectively with the J, K, L and M 
parameters and the X0 and Y0 parameters provided on 
the output data buses from the mini-computer 552. 
These registers then provide storage for the four pa¬ 
rameters plus initial points applied to a function gener¬ 
ator 568 which may be any of the designs indicated 
above. The computer output data bus is also tied into 
the generator 568 for start and stop information as 
well. The X and Y time varying output signals from the 
generator 568 are applied to a display system 570 as 
desired. 

While a complete set of program listings in the FOR¬ 
TRAN language for use with computers accepting that 
language are presented in Appendix A it is instructive 
to discuss here in detail the programming operation for 
case II in a situation where a sequence of linked strokes 
are to be displayed with continuity and smoothness be¬ 
tween the strokes provided by matching the beginning 
and ending slopes for adjacent strokes as can be done 
using the case II conversions. In this case FIG. 19 pro¬ 
vides a detailed flow chart governing the operation of 
the computer 552 for this mode of operation. In partic¬ 
ular, in FIG. 19 the computer 552 is programmed to 
operate from an initiallization operation 580. A subse¬ 
quent operation 582 responds to input data indicative 
of the initial slope SO for point P0 as may be entered 
from the keyboard 550 or other data sources such as on 
line processors or disk and tape readers 584 in FIG. 18. 
Operation 582 also reads in the X and Y coordinates 
for the beginning and ending points of the intermediate 
point for the case II conditions. A subsequent operation 
584 computes the A, B, C, D, and E intermediate vari¬ 
ables according to case II. A decision 586 follows 
which tests the value of E and if E is determined to be 
between zero and one in value a subsequent operation 
588 is entered in which the variable F and the ultimate 
J, K. L and M output parameters are computed. A sub¬ 
sequent operation 590 provides the formatting as is ap¬ 
propriate for application to registers for purposes of 
display using known formatting techniques. A subse¬ 
quent operation 592 sends that set of display parame¬ 
ters to the processor 554 for application to the appro¬ 
priate registers and a subsidiary operation 594 results 
in the display of data by the generator 568 and display 
570. Subsequent to operation 592 an operation 596 
computes the slope of the end points for that quarter 
cycle stroke as the ratio of the M and K parameters. 
That slope is then identified as SO, the initial slope for 
the next section. Operation 598 accepts two new points 
and, a subsequent decision 600 determines whether 
zero, one or two points have been received by the com¬ 
puter. If both points have been received processing re¬ 
turns to operation 584, if no points have been received, 
there is an indication of the end of the sequence of 
strokes and decision 600 leads to end status 602. If only 
one point is provided an operation 604 is entered based 
on the assumption that the next section will be speci¬ 
fied according to case I. An operation 604 reads in the 
slope for the terminal point of that section as SI. The 
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one point received is redefined as the terminal point 
and operation 606 is entered in which the A, B, J, K, 
L and M parameters are calculated according to case 
I conversion. Subsequent to operation 606, operation 
5 590 is entered to provide for the formatting of the cal¬ 
culated parameters for purposes of display. 

If, in decision 586, the intermediate variable E was 
outside the range of zero to one, indicating bad data, 
an operation 610 is entered to cancel the last two 
10 points and to inform the operator that an additional 
two points must be supplied in order to satisfy the con¬ 
straints of the particular mathematics being employed. 
Processing returns to operation 598. 

Referring now to FIG. 20 a three dimensional rota- 
15 tion display processor is indicated and may be em¬ 
ployed with a three dimensional tool controller or dis¬ 
play having a Z axis input. The J, K, L and M signals 
are applied to a multiplexer 612 through a presettable 
decoder 616. Multiplexer 512 also receives N and P 
20 signals representing deflection coefficients which are 
initially set to zero. During the initial state of counter 
614, multiplexer 612 connects these inputs to a set of 
registers 618 for application to a plurality of gates 620, 
622, and 624 for respective rotation about X, Y and Z 
25 axes. Gate 620 receives L, M, N and P signals and is 
controlled through decoder 616 to apply these inputs 
to a rotation transformation circuit 626 for rotation 
about the X axis by an angle cr from source 628. J and 
K signals are applied directly to a network 638 by gate 
30 620. Gate 622 receives J, K, N and P signals for con¬ 
trolled application to a rotation transformation circuit 
630 for rotation about the Y axis by an angle <!> from 
source 632. Gate 622 receives the L and M signals for 
direct application to network 638. Similarly gate 624 
35 receives J, K, L and M signals for controlled applica¬ 
tion during a selected state of counter 614 to a Z axis 
rotation transformation circuit 634 which produces Z 
axis rotation by an angle 0 from source 636. Gate 624 
applies the N and P signals directly to network 638. 
40 Circuits 626, 630 and 634 may use the identical com¬ 
ponents as the circuit of FIG. 12, the interconnections 
being arranged to produce the following transformed 
outputs. 

45 Circuit 626 

L'=Lh—Ng sirur 

M'=Mh—Dg /i=costr 

N'=Nh+Lg 
P'=Ph+Mg 

Circuit 630 

Ne e=sin0 

50 K'=Kf—Pe J=costf> 

N'=Nf+Je 

P'=Pf+Ke 

Circuit 634 

J'=Jd—Lc c=sin 6 

K'=Kd—Me d=cos6 

L'=Ld+Jc 

55 M'=Md+Kc 

The transformed J, K, L, M, N and P parameter sig¬ 
nals are applied to OR network 638 where signals of 
the same letter designation are applied to an OR gate 
60 to produce a single output for each parameter. These 
combined outputs are applied to multiplexer 612 
where, during the states of counter 614 subsequent to 
the first, they are applied to registers 618 for recycling 
of the signals through a different rotation circuit to pro- 
65 duce further rotation about an orthogonal angle. Since 
the order of rotation about the three angles is signifi¬ 
cant, decoder 616 is settable to alter which angle of ro¬ 
tation is performed first and which is performed sec- 
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ond. The decoder then responds to the first three states 
of counter 614 to direct the parameter signals to the 
appropriate rotation circuit during each cycle. 

The transformed parameters J, K, L and M from net¬ 
work 636 are applied to an X, Y generator 640 of the 5 
type indicated above while the N and P parameters are 
applied to a generator 642, essentially a single channel 
of the above shown generators to produce a Z(/) signal 
according to the function: 

Z(t)=N[cos{/)—1 ]+Psin(/)+ZO 10 

The resulting X, Y, and Z signals are applied to respec¬ 
tive inputs of a display or tool controller. 

The three dimension case of FIG. 20 can be general¬ 
ized to any number of dimensions where desired for 15 
specific applications. 

Having described above specific implementations of 
a preferred embodiment for the present invention it 
will occur to those skilled in the art that modifications 
and alterations can be made to the disclosed structure 20 
without departing from the spirit of the invention. It is 
accordingly intended to limit the scope of the invention 
only as indicated in the following claims. 


APPENDIX A 

FORTRAN LISTINGS FOR COMPUTE 552 


100 SUBROUTINE CRV22 (XEND,YEND,SBEG,- 
SEND) 

110 COMMON XBEG,YBEG 

120 IF (SBEG.EQ.SEND) GO TO 10 

130 A=XEND—XBEG 

140 B=YEND—YBEG 

150 AJ=(A*SBEG—B)/(SEND—SBEG) 

160 AK—A+AJ 
170 AL=SEND*AJ 
180 AM=B+AL 
190 ITYPE=1 

200 CALL TYPCRV (AJ,AK,AL,AM,ITYPE) 

210 RETURN 

220 10 PRINT, “ERROR: SBEG=SEND” 

230 RETURN 
240 END 

400 SUBROUTINE CRV3B (XINTER, YINTER,X- 
END,YEND,SBEG) 

410 COMMON XBEG,YBEG 
420 A=XEND—XBEG 


430 B=YEND—YBEG 
440 C=XEND—XINTER 
450 D=YEND—YINTER 

460 E=((SBEG*C~D)/(SBEG*A-B ))**2 50 

470 IF (E.GTT.) GO TO 10 
480 F=SQRT (l.-E) 

490 AK=(A*E-C)/(E+F-1.) 

500 AJ=AK—A 

510 AM=SBEG*AK 55 

520 AL=AM—B 
530 ITYPE=1 

540 CALL TYPCRV (AJ,AK,AL,AM,ITYPE) 

550 RETURN 

560 10 PRINT, “ERROR: PT OF INFLECTION 60 
BTWN BEG+INTER PT” 

570 RETURN 
580 END 

700 SUBROUTINE CRV3I (XINTER,YINTER,X- „ 
END,YEND,SINTER) 

710 COMMON XBEG,YBEG 
720 A=XEND—XBEG 


730 B=YEND—YBEG 

740 C=XINTER—XBEG 

750 D=YINTER—YBEG 

770 AP=YEND—SINTER*XEND 

780 BP=YINTER-SINTER*XINTER 

790 CP=YBEG—SINTER*XBEG 

800 DP=(CP—BP)/(AP-BP) 

810 IF (DP.LT.0.) GOTO 10 

820 E=( 1DP+DP*SQRT(2.*DP))/(DP**2+1.) 

830 F=SQRT (l.-E**2) 

840 AJ=( C—A * F)/ (E+F— 1.) 

850 AL=(D—B*F)/(E+F—1.) 

860 AK=AJ+A 
870 AM=AL+B 
880 ITYPE=1 

890 CALL TYPCRV (AJ,AK,AL,AM,ITYPE) 

900 RETURN 

910 10 PRINT, “ERROR: ROUTINE CRV3I” 

920 RETURN 
930 END 

1100 SUBROUTINE CRV3E (XINTER,YINTER,X- 
END,YEND,SEND) 

1110 COMMON XBEG,YBEG 
1120 A=XEND—XBEG 
1130 B=YEND—YBEG 
1140 C=XINTER—XBEG 
1150 D=YINTER—YBEG 
1 160 E=((SEND*C-D)/(SEND*A-B ))**2 
1170 IF (E.GT. 1.) GO TO 10 
1180 F=SQRT(1.-E) 

1190 AK=(A*F—(XEND—XINTER))/(E+F— 1 .) 

1200 AJ==AK—A 

1210 AL=SEND*AJ 

1220 AM=AL+B 

1230 ITYPE=1 

1240 CALL TYPCRV (AJ,AK,AL,AM,ITYPE) 
1250 RETURN 

1260 10 PRINT, “ERROR: PT. OF INFLECTION 
BTWN INTER AND END PT.” 

1270 RETURN 
1280 END 

1400 SUBROUTINE CRVMAX (XMAX,YMAX,X- 
END,YEND) 

1410 COMMON XBEG,YBEG 
1420 SINTER=( YEND-YBEG)/(XEND-XBEG) 
1430 CALL CRV3I (XMAX,YMAX,XEND- 
,YEND,SINTER) 

1440 RETURN 
1450 END 

1600 SUBROUTINE CIRCLE (XCTR.YCTR- 
,RADIUS) 

1620 X=XCTR—RADIUS 
1630 CALL CURSET (X,YCTR) 

1640 AJ=—RADIUS 
1650 AK=0 
1660 AL=0 
1670 AM=RADIUS 
1680 ITYPE==4 

1690 CALL TYPCRV (AJ,AK,AL,AM,ITYPE) 

1700 RETURN 
1710 END 

1900 SUBROUTINE SEMI (XEND,YEND,IDIREC) 

1910 COMMON XBEG,YBEG 
1920 A=(XEND—XBEG )/ 2 . 

1930 B=( YEND-YBEG )/2. 

1940 IF (IDIREC.EQ. 1) GO TO 10 
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1950 AJ=A 
1960 AK=B 
1970 AL=B 
1980 AM=—A 

1990 GO TO 20 - 

2000 10 AJ=A 

2010 AK=^B 

2020 AL=B 

2030 AM=A 

2040 20 ITYPE=2 , 0 

2050 CALL TYPCRV (AJ,AK,AL,AM,ITYPE) 

2060 RETURN 
2070 END 

2200 SUBROUTINE ELLPSA (XCTR,YCTR AN¬ 
GLE, AM AJOR.AMINOR) 15 

2210 R=(3.14159*ANGLE)/l80. 

2220 AJ=AMAJOR*COS(R) 

2230 AK=AMINOR*SIN(R) 

2240 AL=AMAJOR*SIN(R) 

2250 AM=AMINOR*COS(R) 20 

2260 ITYPE=4 

2270 X=AJ+XCTR 

2280 Y=AL+YCTR 

2290 CALL CURSET (X,Y) 

2300 CALL TYPCRV (AJ,AK,AL,AM,ITYPE) 25 
2310 RETURN 
2320 END 

2500 SUBROUTINE ELLPSE (XCTR,YCTR,AX- 
END,A YEND,ALGTH ) 

2510 CALL CURSET (AXEND,AYEND) 30 

2520 A=AYEND—YCTR 
2530 B=AXEND—XCTR 
2540 C=SQRT (A* * 2+B * * 2) 

2550 AL=A 

2560 AJ=B 35 

2570 AM=ALGTH*(B/C) 

2580 AK=-ALGTH*(A/C) 

2590 ITYPE=4 

2600 CALL TYPCRV (AJ,AK,AL,AM,ITYPE) 

2610 RETURN 40 

2620 END 

2800 SUBROUTINE VECTOR (X,Y) 

2810 COMMON XBEG.YBEG 
2820 A=X—XBEG 

2830 B=Y—YBEG 45 

2840 NODRAW=0 

2850 CALL VECT (A,B,NODRAW) 

2860 RETURN 
2870 END 

3000 SUBROUTINE CURSET (X,Y) 50 

3010 COMMON XBEG,YBEG 

3020 A=X—XBEG 

3030 B=Y—YBEG 

3040 NODRAW=128 

3050 CALL VECT (A,B,NODRAW) 55 

3060 RETURN 
3070 END 

3200 SUBROUTINE VECT (X.Y.NODRAW) 

3210 COMMON XBEG.YBEG,JPTR,NBFSIZ 
3220 IF ((NBFSIZ—JPTR).LT.2) CALL OUTPUT 60 
3230 CALL SHTFMT (X.0) 

3240 CALL SHTFMT (Y.NODRAW) 

3250 N=8 

3260 10 CALL RNDOFF (X,Y,N) 

3270 XBEG=X 65 

3280 YBEG=Y 
3290 RETURN 
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3300 END 

3500 SUBROUTINE FINISH 
3510 COMMON XBEG.YBEG.JPTR,NBFSIZ N- 
BUFF(1000) 

3515 DATA 11,12,13/0300,0222,0214/ 

3520 IF ((NBFSIZ—JPTR).LT.3) CALL OUTPUT 

3530 NBUFF(JPTR)=I 1 

3540 NBUFF (JPTR+1 )=I2 

3550 NBUFF(JPTR+2)=I3 

3560 CALL OUTPUT 

3570 RETURN 

3580 END 

3700 SUBROUTINE DISPLY 
3710 COMMON XBEG,YBEG.JPTR,NBFSIZ N- 
BUFF(1000) 

3715 DATA 11,12,13/0300,0301,0203/ 

3720 IF ((NBFSIZ—JPTR).LT.3) CALL OUTPUT 

3730 NBUFF(JPTR)=I1 

3740 NBUFF(JPTR+1 )=I2 

3750 NBUFF(JPTR+2)=I3 

3760 CALL OUTPUT 

3770 RETURN 

3780 END 3900 SUBROUTINE POINT (X Y) 

3910 CALL CURSET(X.Y) 

3920 CALL VECTOR (X,Y) 

3930 RETURN 
3940 END 

4100 SUBROUTINE ROTATE (NROTFL.N X- 
ROT.YROT, ANGLE) 

4110 COMMON XBEG.YBEG 
4120 DIMENSION NROTFL(N) 

4130 DATA MASK/0200/ 

4140 PHI=(3.14159*ANGLE)/180. 

4150 SINPHI=SIN( PHI) 

4160 COSPHI=COS( PHI) 

4170C FIND NEW STARTING POINT 

4180 A=XBEG—XROT 

4190 B=YBEG—YROT 

4200 X=A*COSPHI-B*SINPHI 

4210 Y=B*COSPHI+A*SINPHI 

4220 NODRAW=128 

4230 CALL VECT (X,Y.NODRAW) 

4240 1=1 

4250 10 IF (I.GT.N) RETURN 
4260 20 J=AND(NROTFL(I),MASK) 

4270 IF (J.NE.0) GO TO 50 
4280C VECTOR 

4290 NODRAW=AND(NROTFL(I=l),MASK) 

4300 CALL XTRACT (NROTFL(I),A) 

4310 CALL XTRACT (NROTFL(I+l ),B) 

4320 DELTAX=A*COSPHI—B*SINPHI 
4330 DELTAY=B*COSPHI+A*SINPHI 
4340 CALL VECT (DELTAX.DELTAY,NO¬ 
DRAW) 

4350 1=1=2 
4360 GO TO 10 
4370C CURVE 

4380 50 L=AND(NROTFL( 1=2),MASK) 

4390 M=AND(NROTFL( 1=3),MASK) 

4400 ITYPE=L/128+M/128+1 
4410 CALL XTRACT(NROTFL( I),A) 

4420 CALL XTRACT (NROTFL(I=l ),B) 

4430 CALL XTRACT (NROTFL(I=2),C) 

4440 CALL XTRACT (NROTFL(I=3),D) 

4450 AJ=A*COSPHI—C*SINPHI 
4460 AK=B*COSPHI—D*SINPHI 
4470 AL=A*SINPHI+C*COSPHI 
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4480 AM=B*SINPHI+D*COSPHI 

4490 CALL TYPCRV (AJ,AK,AL,AM,ITYPE) 

4500 1=1=4 
4510 GO TO 10 

4520 END 5 

4700 SUBROUTINE XTRACT (I,A) 

4710 DATA MASKl,MASK2/0100,077/ 

4720 J=AND(MASK 1,1) 

4730 K=AND(MASK2,I) 

4740 B=K 10 

4750 IF (J.NE.O) B=-(64-K) 

4760 A=B/8. 

4770 RETURN 
4780 END 

5000 SUBROUTINE IN1T (ISCALE) 15 

5010 COMMON XBEG,YBEG,JPTR,NBFSIZ,N- 
BUFF(1000) 

5020 DIMENSION 1(18) 

5030 DATA 

(I{K),K= 1,9)/0202,0233,0300,0300,0301,0230,0- 20 
301,0266,0000/ 

5040 DATA 

(I( K ),K= 10,18 )/0,0300,0234,00,0,0,0,0300,0236/ 


5050 DO 20 K=l, 18 25 

5060 20 NBUFF (K)=I(K) 

5070 NBUFF( 10)=ISCALE*8 
5080 JPTR=19 
5090 XBEG=0. 

5 100 YBEG=0. 30 

5110 RETURN 
5 120 END 

10000 SUBROUTINE SHTFMT (A,N) 

10010 COMMON XBEG,YBEG,JPTR,NBFSIZ,N- 
BUFF(1000) 35 

10020 DATA MASK /0177/ 

10030 L=A*8. 

10040 I=AND(MASK,L) 

10050 NBUFF(JPTR )=I+N 

10060 JPTR=JPTR+1 40 

10070 10 RETURN 

10080 END 10200 SUBROUTINE RNDOFF 
(A,B,N) 

10210 1=A*N 

10220 J=B*N 45 

10230 C=N 

10240 A=I/C 

10250 B=J/C 

10260 10 RETURN 

10270 END 50 

10400 SUBROUTINE TYPCRV (AJ,AK,AL,AM- 
,ITYPE) 

10410 COMMON XBEG,YBEG,JPTR,NBFSIZ 
10420 IF ((NBFSIZ—JPTR).LT.4) CALL OUTPUT 

10430 J=128 
10440 K=0 
10450 N=8 

10460 GO TO (31,32,33,34),ITYPE 

10470 31 L=0 60 

10480 M=0 

10490 GO TO 40 

10500 32 L=0 

10510 M=128 

10520 GO TO 40 65 

10530 33 L=f 28 
10540 M=0 


10550 GO TO 40 
10560 34 L=128 
10570 M=128 

10580 40 CALL SHTFMT (AJ,J) 

10590 CALL SHTFMT (AK,K) 

10600 CALL SHTFM (AL,L) 

10610 CALL SHTFMT (AM,M) 

10620 50 CALL RNDOFF (AJ,AK,N) 

10630 CALL RNDOFF (AL.AM.N) 

10640 GO TO (61, 62, 63, 64), ITYPE 
10650 61 XBEG=XBEG—AJ+AK 
10660 YBEG=YBEG—AL+AM 
10670 RETURN 
10680 62 XBEG=XBEG—2.*AJ 
10690 YBEG=YBEG—2.*AL 
10700 RETURN 

10710 63 XBEG=XBEG—AJ—AK 
10720 YBEG=YBEG—AL—AM 
10730 64 RETURN 
10740 END 
What is claimed is: 

1. A system for providing X and Y orthogonal control 
signals comprising: 

means for receiving point and slope data representa¬ 
tive of strokes to be executed under the control of 
said X and Y control signals; 
means responsive to said received data for develop¬ 
ing a set of four control parameters: 
means for generating a set of quadrature phased sinu¬ 
soidally varying signals scaled in accordance with 
the values of said control parameters to provide a 
set of four scaled sinusoidally varying signals; 
means for causing said four sinusoidally varying sig¬ 
nals to be generated for a selected portion of a cy¬ 
cle; 

means for combining said four time varying signals in 
pairs to produce said X and Y function control sig¬ 
nals; and 

said means for developing said four control parame¬ 
ters from said received point and slope data being 
operative to develop said parameters according to 
a predetermined transformation which defines said 
parameters as the coefficients of summed sine and 
cosine function signals that represent orthogonal 
coordinates of an elliptical stroke constrained by 
said received point and slope data. 

2. The system of claim 1 wherein said selected por¬ 
tion of a cycle is a quarter cycle. 

3. The system of claim 2 wherein: 

said received point and slope data represents the ter¬ 
minal point coordinates (X0, Y0; Xl, Yl) and 
slopes (SO; SI) of a stroke; and 
said developing means is operative to provide a cor¬ 
responding transformation on said received data to 
produce said set of four parameters (J, K, L, M). 

4. The system of claim 3 wherein the transformation 
of said developing means relates said four parameters 
to said received point and slope data according to the 
following equations: 

A=X1—X0; B=Y 1—Y0 
J=[(SO)A—B]/(S1—SO) 

K=A+J 

L=(S1)J 

M=B+L 

5. The system of claim 2 wherein: 
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said received point and slope data represents the ter¬ 
minal point coordinates (X0, Y0; XI, Yl) and the 
coordinates of an intermediate point (X3, Y3) for 
a stroke and the slope (SO, SI, S3) of one of the 
three points; and 5 

said developing means is operative to provide a cor¬ 
responding transformation on said received data to 
produce said set of four parameters (J, K, L, M). 


6 . The system of claim 5 wherein the transformation 10 
of said dveloping means relates said four parameters to 
said received point and slope information according to 
the following equations: 

A=X1—X0; B=Y1-Y0 

C=X1-X3; D=Y1—Y3 15 

E=[(S0)C—D]/[(S1)A—B]; F= V1-(E)(E) 

K=( AE—C)/(E+F—1) 

J=K—A 
M=(SO)K 

L=M-B 20 

7. The system of claim 5 wherein the transformation 
of said developing means relates said four parameters 
to said received point and slope information according 
to the following equations: 

A=X1—X0; B=Y1-Y0 25 

C=X3—X0; D=Y3-Y0 
E=[(S1)C—D]/[(S1)A—B]; F= V1-(E)(E) 
K=[(X3-X1)+AF]/(E+F-1) 

J=K—A 

L=( S1)J 30 

M=L+B 

8 . The system of claim 5 wherein the transformation 
of said developing means relates said four parameters 
to said received point and slope information according 

to the following equations: 35 

A=X1-Y0; B=Y1—Y0 
C=X3—X0; D=Y3—Y0 
H=X3—XI; I=Y3—Yl 
G=[ (S3)C—D]/[(S3)H—1 ]; 

E=[ 1+G( V2G—1)]/[ 1+(G)(G)] 40 

F= Vl—(E)(E) 

J=( C—AF)/(E+F—1) 
k=J+A 

L=(D—BF)/(E+F—1) 

M=L+B 45 

9. The system of claim 2 wherein; 

said received point and slope data represents the ter¬ 
minal point coordinates (X0, Y0; XI, Yl) of a 
stroke and a third intermediate point (X2, Y2) at 
the maximum displacement from a straight line be- 50 
tween the terminal points; and 
said developing means is operative to provide a cor¬ 
responding transformation on said received data to 
produce said set of four parameters (J, K, L, M). 


10. The system of claim 9 wherein the transformation 
of said developing means relates said four parameters 
to said received point and slope data according to the 
following equations: 

A=Xl-XO; B=Y1—YO 
C=X2—X0; D=Y2-YO 
R=l/V2j T=1/(V2—1) 

J=(C-AR)T 
K=J+A 
L=(D—BR)I 
M=L+B 
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11. The system of claim 1 further including: 
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controllable marking means responsive to said X and 

Y control signals for providing in viewable form a 
curve section representative thereof; 

means for establishing magnitude limits to said X and 

Y control signals; 

means for detecting when said control signals exceed 
said limits;-and 

means for inhibiting marking by said controllable 
marking means in response to detection of said 
control signals exceeding said limits. 

12. The system of claim 11 further including: 
means for controlling the rate of variation of said X 

and Y control signals; and 
means operative in response to detection of said con¬ 
trol signals exceeding said limits for increasing the 
rate of variation of said X and Y control signals. 

13. A system for providing X and Y orthogonal con¬ 
trol signals comprising: 

means for producing four parameters to represent 
input data; 

means for storing values representing the sine and co¬ 
sine functions for predetermined portions of a cy¬ 
cle; 

controllable means for retreiving said stored values 
to provide sine and cosine signals; 
means controlled by first and second ones of said 
four parameters for providing first and second out¬ 
put signals representing said sine signal adjusted 
according to the value of said first and second pa¬ 
rameters; 

means controlled by third and fourth ones of said 
four parameters for providing third and fourth out¬ 
put signals representing said cosine signal adjusted 
according the value of said third and fourth param¬ 
eters; 

first means for developing said X control signal to 
represent a combination of said first and third out¬ 
put signals; and 

second means for developing said Y control signal to 
represent a combination of said second and fourth 
output signals. 

14. The system of claim 13 wherein said means for 
providing said first, second, third, and fourth output 
signals include binary rate multipliers having sequences 
of elemental signals as outputs. 

15. The system of claim 14 wherein: 

said means are provided for detecting the quadrant 
represented by said sine and cosine signals; 
means are provided for detecting the sign of said first 
and third parameters; 

said first developing means includes means respon¬ 
sive to the detected quadrant and detected sign of 
said first and third parameters for identifying each 
elemental signal in said X control signal as an in¬ 
creasing or decreasing elemental change; 
means are provided for detecting the sign of said sec¬ 
ond and fourth parameters; and 
said second developing means includes means re¬ 
sponsive to the detected quadrant and detected 
sign of said second and fourth parameters for iden¬ 
tifying each elemental signal in said Y control sig¬ 
nal as an increasing or decreasing elemental 
change. 

16. The system of claim 14 further including means 
for controlling the rate of generation of said elemental 
signals to provide regulation in the rate of change of 
said X and Y control signals. 
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17. The system of claim 16 wherein: 
a source of clock signals is provided; 

said controllable means includes first and second bi¬ 
nary rate multipliers responsive to said stored val¬ 
ues and said clock signals to provide a series of ele- 5 
mental signals as said sine and cosine signals; and 

said controllable means is operative to inhibit said 
clock signals for a predetermined interval after 
each elemental signal in said first, second, third and 10 
fourth output sequence. 

18. The system of claim 13 further including: 
means responsive to said X and Y control signals for 

moving a part; and 

means for controlling the generation of said sine and 15 
cosine signals to limit accelerations of said part 
represented by said X and Y control signals. 

19. A system for producing X and y orthogonal con¬ 
trol signals representing a curve section in response to 
input data including curve terminations and operative 20 
to provide predetermined transformations to said con¬ 
trol signals, said system comprising: 

means for receiving said input data; 
means responsive to said received input data for de¬ 
veloping a set of plural control parameters; 
means responsive to said control parameters for pro¬ 
ducing a set of transformed control parameters to 
represent a predetermined manipulation on said 
curve section as realized by a direct alteration on 30 
said control parameters and without introducing 
distortions to said curve section other than said 
predetermined manipulations; 
means for generating a set of sinusoidally varying sig¬ 
nals scaled in response to said transformed control 35 
parameters; and 

means for combining said scaled, sinusoidally varying 
signals to provide said X and Y orthogonal control 
signals. 

20. The system of claim 19 wherein said predeter- 40 
mined manipulation is a rotation by a selected angle 
about an axis orthogonal to the plane of said X and Y 
control signals. 

21. The system of claim 20 wherein said producing 
means is operative to provide each parameter of said 45 
set of transformed parameters as the combination of 
two of said control parameters scaled by a trigonomet¬ 
ric function of said selected angle. 

22. The system of claim 19 wherein said producing 
means includes means for providing a rotation in a 50 
space described by more than two dimensions. 

23. The system of claim 22 wherein: 

said set of control parameters includes additional pa¬ 
rameters to represent one or more dimensions 
other than the X and Y dimensions; ^ 

said transformed parameter producing means is oper¬ 
ative in response to said set of control parameters 
including said additional parameters to provide 
transformed control parameters representing a ro¬ 
tation about an axis other than the axis orthogonal 60 
to the plane of said X and Y control signals; 
said generating means is responsive to said set of 
transformed control parameters including said ad¬ 
ditional transformed parameters to provide said 6J 
scaled sinusoidally varying signals including further 
sinusoidally varying signals scaled in response to 
said additional transformed parameters; and 


said combining means is operative to provide addi¬ 
tional orthogonal control signals as combinations 
of said further scaled, sinusoidally varying signals. 

24. The system of claim 23 wherein said transformed 
parameter producing means include: 

a plurality of means each responsive to one of a plu¬ 
rality of selected angles of rotation to provide a 
corresponding transformation on a portion of said 
set of control parameters; and 
means for providing sequential operation of said plu¬ 
rality of means to produce said transformed control 
parameters. 

25. The system of claim 19 wherein said producing 
means is operative to produce right angle rotations and 
reflections as the manipulations of said curve section. 

26. The system of claim 25 wherein said producing 
means further includes means for providing as said 
transformed parameters, predetermined combinations 
of said control parameters and the negative of said con¬ 
trol parameters. 

27. The system of claim 19 wherein said producing 
means includes means for scaling said control parame¬ 
ters to alter the size of said curve section. 

28. The system of claim 19 wherein: 

said control parameters include initial point corrdi- 
nates; and 

said producing means includes means for adding first 
and second offset constants to said intial point co¬ 
ordinates. 

29. A system for generating orthogonal X and Y con¬ 
trol signals to represent predetermined strokes, said 
system including: 

addressable means for storing a plurality of instruc 
tion sets; 

each of said instruction sets including one or more 
sets of generally different parameters; 
means for generating a plurality of sinusoidally vary¬ 
ing signals scaled in response to a set of parame¬ 
ters; 

means for responding sequentially to each stored set 
of parameters for application of each set of param¬ 
eters to said generating means; and 
means for combining each sequence of generated 
scaled sinusoidally varying signals to provide the X 
and Y control signals for each of said predeter¬ 
mined strokes. 

30. The system of claim 29 wherein: 

means are provided for reducing the scale of each se¬ 
quential set of parameters before application to 
said generating means; and 
said stored parameters are stored in augmented scale 
to provide a greater number of terminal points 
available for each of said predetermined strokes. 

31. A system for generating X and Y orthogonal con¬ 
trol signals to represent linked curve sections having 
smooth transitions comprising: 

means for receiving data representing points on said 
curve sections; 

means responsive to received data for developing a 
set of control parameters; 

means for generating for a selected portion of a cycle 
a plurality of sinusoidally varying signals scaled in 
response to said set of paramters; 
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means for combining said scaled sinusoidally varying 
signals to provide said X and Y orthogonal control 
signals; 

means for determining the relative variations in said 
X and Y control signals at the terminal point of said 5 
X and Y control signals for each selected portion 
of a cycle; and 

means responsive to further received data and said 
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determined relative variation for developing a fur¬ 
ther set of control parameters for a subsequent set 
of X and Y control signals for an adjacent curve 
section having an initial relative slope matching the 
slope of the terminal point of the preceeding curve 
section. 
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